# Digital Systems Design and Laboratory [Lab 2. Pipelined Multiplier]

TA: Sheng-Ya Lin

**CSIE Department** 

**National Taiwan University** 

- **☐** Multiplier
- Pipeline
- ☐ Fast Multiplier
- ☐ Assignment
- ☐ Appendix

#### Definition

- ☐ Unsigned multiplier
  - Multiplicand × Multiplier = Product
  - Signed multipliers will not be covered in Lab 2

Multiplying N-bit number by M-bit number gives (N+M)-bit result

#### Metrics

- ☐ For an n-bit × n-bit multiplier
- ☐ Latency (longest propagation delay)
  - $> \approx 2n*delay(FA)$
- ☐ Throughput (operations per second)



- Multiplier
- **☐** Pipeline
- ☐ Fast Multiplier
- ☐ Assignment
- ☐ Appendix

## How to Increase Throughput?

- ☐ Cut the circuit into different stages
- Do different tasks in each stage at the same time
- Does the latency change? How about the throughput?



## Pipelined Multiplier

- ☐ Add registers at the end of each stage to keep states
- $\square$  x[3:0] and y[3:0] should also be kept in each stage



- Multiplier
- Pipeline
- **☐** Fast Multiplier
- ☐ Assignment
- ☐ Appendix

## Popular Techniques

- ☐ Carry-save adder
- Wallace tree
- ☐ High-radix
- ☐ And more ...

## A Hierarchical Design



## A Hierarchical Design



- Multiplier
- Pipeline
- ☐ Fast Multiplier
- **☐** Assignment
- ☐ Appendix

#### Execution

- ☐ Download the sample code
- Compile
  - >> iverilog -o lab2.vvp lab2.v
- ☐ Simulate
  - >> vvp lab2.vvp
    - Generates lab2.vcd
- ☐ View waveform
  - >> gtkwave lab2.vcd lab2.sav

## Requirements (1/2)

- ☐ Replace **<index>** in **lab2.v** with proper indexes
  - Leave the rest of the code unchanged
- ☐ Show your source code
- ☐ Show the waveform with the settings in lab2.sav
- What is the latency?
  - Worst case waiting time from the input becomes steady to the register of the last stage refreshes
  - > Use tick as time unit

## Requirements (2/2)

- Minimize the clock cycle by <u>changing the delays</u> in the module mult\_tb
  - What is the minimum clock cycle?
    - Use tick as time unit
  - > Show the waveform with the settings in lab2.sav
    - Should include 1750 to 1800 sec

- Multiplier
- Pipeline
- ☐ Fast Multiplier
- ☐ Assignment
- **□** Appendix

## Multiplier and Pipelining

- ☐ Signed multiplier
  - http://courses.csail.mit.edu/6.111/f2008/handouts/L09.pdf
- Details on pipelining
  - https://www.slideshare.net/siddiqueibrahim37/pipelining-41608675
- Details on fast multiplier
  - https://link.springer.com/article/10.1007/s11265-012-0657-7

#### Some Details on Verilog

- Expression bit width
  - http://yangchangwoo.com/podongii X2/html/technote/TOOL/MANUAL /21i doc/data/fndtn/ver/ver4 4.htm
- Event queue
  - > Determine the order of different types of assignment
  - http://www.ece.lsu.edu/v/2015/lsli-event-q.pdf
- ☐ Transport delay and inertial delay
  - http://wwwinst.eecs.berkeley.edu/~cs152/fa06/handouts/CummingsHDLCON1999 BehavioralDelays Rev1 1.pdf

## Q&A